package com.wgh.product.mapper;

import com.wgh.product.entity.shop.ProductTag;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 商品标签Mapper接口
 * 
 * @author AI Shop
 */
@Mapper
public interface ProductTagMapper extends BaseMapper<ProductTag> {

    /**
     * 查询启用的标签
     * 
     * @return 启用的标签列表
     */
    @Select("SELECT * FROM shop_product_tag WHERE status = 1 AND del_flag = 0 ORDER BY sort ASC")
    List<ProductTag> selectEnabledTags();

    /**
     * 根据标签名称查询标签
     * 
     * @param name 标签名称
     * @return 标签信息
     */
    ProductTag selectByName(@Param("name") String name);

    /**
     * 查询标签关联的商品数量
     * 
     * @param tagId 标签ID
     * @return 商品数量
     */
    int countProductsByTagId(@Param("tagId") Long tagId);

    /**
     * 更新标签状态
     * 
     * @param ids 标签ID列表
     * @param status 状态
     * @return 影响行数
     */
    int updateStatusBatch(@Param("ids") List<Long> ids, @Param("status") Integer status);

    /**
     * 搜索标签
     * 
     * @param keyword 搜索关键词
     * @return 标签列表
     */
    List<ProductTag> searchTags(@Param("keyword") String keyword);

    /**
     * 分页查询标签
     * 
     * @param pageNum 页码
     * @param pageSize 每页数量
     * @return 标签列表
     */
    List<ProductTag> selectPage(@Param("pageNum") Integer pageNum, @Param("pageSize") Integer pageSize);
}